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Abstract 

We study the problem of preemptive scheduling n jobs with given release times on m identical 
parallel machines. The objective is to minimize the average flow time. We show that when all 
jobs have equal processing times then the problem can be solved in polynomial time using linear 
programming. Our algorithm can also be applied to the open-shop problem with release times 
and unit processing times. For the general case (when processing times are arbitrary), we show 
that the problem is unary NP-hard. 

1 Introduction 

In the scheduling problem we study, the input instance consists of n jobs with given release times and 
processing times. The objective is to compute a preemptive schedule of those jobs on m machines 
that minimizes the average flow time or, equivalently, the sum of completion times, ^Cj. In the 
standard scheduling notation, the problem can be described as P\rj, pmtn| Cj. 

First, we focus on the case when all jobs have the same processing time p, that is P\rj,pj = 
p, pmtn| Cj- Herrbach and Leung [4; showed that, for m = 2, the optimal schedule can be com- 
puted in time O(nlogn). For more machines, the complexity of the problem was open. Addressing 
this open problem, we present an algorithm whose running time is polynomial in m and n. 

Our algorithm is based on linear programming. We show that there is always an optimal 
schedule in a certain normal form. We then give a simple linear program of size 0(mn), which 
directly defines an optimal normal schedule. Since the coefficients in the constraints of our linear 
program are —1, 0, or 1, the result of Tardos |S| implies that the problem can be solved in worst 
case time 0(n 5 m 5 ). 
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We show that, without loss of generality, we can assume that the preemptions occur only at 
integer times. This yields a polynomial-time algorithm for the open shop problem 0\ri,pij = 
l|^Cj, for it is known that this problem is equivalent to P\ri,pi = m,pmtn + | £Cj, where m is 
the number of machines [2]. (Notation pmtn + means that preemptions are allowed only at integer 
times.) Previously, it was only known that this problem can be solved in polynomial time if m is 
constant [§]. 

In the open shop problem 0\rt,pij = l|£Cj each job has to be processed on each machine 
exactly once and with a unit processing time. At any time each machine can execute at most one 
job and every job can be scheduled by at most one machine. No job can start before its given 
release time, and the goal is to minimize the total completion time. 

In the last section we consider the general case, when the processing times are arbitrary. Du, 
Leung and Young [3] proved this problem is binary NP-hard for two machines. We show that if 
the number of machines is not fixed then the problem is in fact unary NP-complete. 

We summarize the results discussed above in Tabled 



Problem 


Complexity 


P2 


Tj \ pmtn; p.,- 


= p\ECj 


solvable in time 0(n log n) [1] 


P 


Tj \ pmtn; p.,- 


= p\ECj 


solvable in polynomial time [this paper] 


P2 


Vj ; pmtn 




binary NP-hard [Hj 


P 


Vj ; pmtn 


\ECj 


unary NP-complete [this paper] 


P 


pmtn; pj 


= p|£c* 


solvable by the greedy algorithm (trivial) 


P 


r v Pj 


= p\ECj 


solvable by the greedy algorithm (trivial) 


1 


r j] pmtn; pj 


= p\E w jCj 


open 


P 


rj ; pmtn; pj 


= p\EwjCj 


unary NP-complete [0] 


O 


fj ; Pji 


= MECj 


solvable in 0(n 2 m 6m ) in polynomial time [this paper] 



Table 1: Complexity of related scheduling problems. P2 stands for the two-machine problem, 
and O for the open-shop problem. In problems with the objective function ^WjCj, each job j is 
assigned a weight Wj > 0, and the goal is to minimize the weighted sum of all completion times. 



2 Structural Properties 

Basic definitions. Throughout the paper, n and m denote, respectively, the number of jobs 
and the number of machines. The jobs are numbered 1,2, ... , n and the machines are numbered 
1,2, ... ,m. All jobs have the same length p. For each job j, rj is the release time of j, where, 
without loss of generality, we assume that = r% < . . . < r n . In this section we assume that all 
numbers p,r±, . . . ,r n are integers; in the appendix we show that our results can be extended to 
arbitrary real numbers. 

We define a schedule X to be a function which, for any time t, determines the set X(t) of jobs 
that are running at time t. This set X{t) is called the profile at time t. Let Af _1 (j) denote the 
set of times when j is executed, that is X~ l {j) = {t : j 6 X(t)}. In addition we require that X 
satisfies the following conditions: 

(si) At most m jobs are executed at any time, that is |#(£)| < m for all times t. 
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(s2) No job is executed before its release time, that is, for each job j, if t < rj then j ^ X(t). 

(s3) Each job runs in a finite number of time intervals. More specifically, for each job j, X _1 (j) 
is a finite union of intervals of type [s,t). 

(s4) Each job is executed for time p, that is = p. 

In (s4), for a set X of real numbers we use |X| to denote its measure. It is not difficult to see 
that condition (s3) can be relaxed to allow jobs to be executed in infinitely (but countably) many 
intervals, without changing the value of the objective function. 

By Cj = sup X~ l (j) we denote the completion time of a job j. In this paper, we are interested 
in computing a schedule that minimizes the objective function Y^j=i Cj- 

Note that, since we are dealing with preemptive schedules, it does not matter to which specific 
machines the jobs in X(t) are assigned to. When such an assignment is needed, we will use the 
convention that the jobs are assigned to machines in the increasing order of indices (or, equivalently, 
release times): the job with minimum index is assigned to machine 1, the second smallest job to 
machine 2, etc. 

Integral schedules. We say that a schedule X is integral, if X (t) is constant for t £ [s, s + 1) at 
any s € N. (In other words, all preemptions occur at integer times.) The following lemma is due 
to PP, and we include it here for the sake of completeness. 

Lemma 1 There exists an optimal schedule X that is integral. 

Proof: Let X be an arbitrary optimal schedule. We will show that there is an integral schedule 
X' whose objective value is not greater than that of X. The proof is based on a flow network 
model of the scheduling problem, and uses the fact that if all capacities are integral then there is 
an integral solution. 

Let Ci, . . . , C n be the completion times in X. We consider the set of all time points 

{ri,... J r n> LC f iJ ) rCil,... > LC n J,rC n l}. 

Suppose that there are k distinct numbers in this set. We rename these numbers t±, t^ and order 
them in increasing order, t\ < . . . < ifc. These numbers define k — 1 intervals [tj, ij+i) for 1 < i < k. 

We define a network which consists of the nodes u\, . . . , u n , v\, . . . , ffe-i, plus two more nodes 
designated as the source and the sink. A node Uj represents job j and a node v- t represents interval 
[ij,ij_l_i). For every job j, there is an arc from the source to Uj with capacity p and cost 0. For 
every time interval [ij, £j+i) there is an arc from Vi to the sink with capacity m(£j+i — ij) and cost 0. 
For every job j and every interval [ti,tj+i) C [rj, \Cj\), there is an arc from Uj to Vi with capacity 
— t{ and cost 0. In addition, for every job j for which Cj is not integral, there is an arc from 
Uj to Vi for ti = [Cj\ with capacity 1 and cost 1. (These are the only arcs with non zero cost.) 

The schedule X corresponds to a flow of value np, where the flow on an arc (uj,Vi) has value 
\X ~ 1 (j')n [ti, The flows on other arcs are uniquely determined by the flows on all arcs [uj,Vi). 

The cost of this flow is w = Xlj=i(Cj — l_CjJ)- 

Now we consider the minimum cost flow with maximal value np in this network. Let its cost 
be w' < w. This minimum cost flow corresponds to a schedule X' in the following manner. For 
each given i, the amount of each job j scheduled in interval [tj,tj + i) is equal to the flow on the 
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arc (uj,Vi), which is bounded by the capacity i = tj + i — t{ of this arc. The total processing time 
mi in this interval is assigned to jobs 1, 2, . . . , n, in this order, processor by processor, and for each 
processor from left to right. Since each (uj,Vi) has capacity £, a job will not be scheduled at two 
processors at the same time. Also, since the capacity of the arc between V{ and the sink is ml, all 
jobs will be allocated the required processing time. 

Since all arcs have integer capacity, the minimum cost flow can be assumed to be integer (see 
[7j.) Therefore the resulting schedule X' is integral. It remains to show that its objective value is 
not larger than that of X . 

For each job j, let C'- be the completion time of j in X'. By the construction of the network, 
we have Cj < \Cf\ . Moreover, for w' jobs j we have Cj = \Cf\ > [Cj\ , and for these jobs Cj is 

not integer, while for all the other n — w' jobs j we have Cj < [CjJ- Setting C = X^=i l/<j'J > the 
cost of X' is 

n n n 

^C'j < C + w' < C + w < C + ~ = J2 C i> 

j=i j=i j=i 

completing the proof of the lemma. □ 

Busy schedules. We now show that, for the purpose of minimizing our objective function, we 
can restrict our attention to schedules with some additional properties. 

We say that a schedule X is busy if it satisfies the following condition: for any two times s < t 
and a job j such that rj < s, if j 6 X(t) and (^(s)! < m (that is, some machine is idle at s) then 
j G X(s) as well. Any optimal schedule is busy, for otherwise, if the above condition is not satisfied, 
we can move a sufficiently small portion e > of j from the last block where it is executed to the 
interval [s, s + e), obtaining a feasible schedule in which the completion time of j is reduced by e and 
other completion times do not change. Thus we only need to be concerned with busy schedules. 

Reductions. Let X be a schedule, and i,j be two jobs with < rj. Let T be the set of times 
where exactly one of the jobs i,j is scheduled, that is T = [Af~ 1 (i) \ X~ l (j)\ U [X~ l (j) \ X~ l (i)\. 
Also, let to be a time point which divides T into two parts of the same size, that is |Tn[0, to)\ = \\T\. 
Since i and j have equal processing time, the processing times of each of i and j in T is equal ^\T\. 
The (i, j) -reduction modifies the schedule by executing i in \T n [0, to) I and j in T n [to, oo). If the 
reduction does not change X (that is, i is executed in T n [0, to) I an d j in T fl [to, oo)) then we say 
that i and j are in order. 

We say that a schedule X is irreducible if it is busy and all pairs of jobs are in order. It is not 
difficult to see that X is irreducible iff it satisfies the following condition for any times s < t: 

m&x(X(s) - X(t)) < mm(X(t) - X(s)), (1) 

where the order refers to job indices, which we assumed to satisfy i < j rj < rj. Also, we 
use the convention that max(0) = — oo and min(0) = +oo, so (0) holds whenever X(s) C X (t) or 
X(t) C X{s). 

Lemma 2 For any two jobs i,j with ri < rj, an (i, j) -reduction of X does not increase the objective 
function, and preserves the integrality and the property of being busy. 
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Proof: In the (i, j')-reduction, only the completion times of i and j might change. Let C{,Cj 
be the completion times of i, j, before the reduction and C[, after the reduction. We have three 
cases. If Ci > Cj then Cj = C and C[ < Cj. If C = Cj, then the completion times do not change. 
If Ci < Cj, then Cj = Cj and C[ < C. Thus in all three cases Ci + Cj does not increase. 

To justify the second part of the lemma, note that the reduction does not change the cardinality 
of X(t) at any time point t. Therefore the new schedule remains busy. Further, if X is integral 
then to can be assumed to be an integer, and the new schedule will then be integral as well. □ 

Theorem 3 There is an optimal schedule X that is irreducible. 

Proof: Let X be an optimal schedule that is busy and integral. We define a potential function 
which decreases strictly when a reduction of two jobs which are not in order is applied. From this 
we conclude that after a finite number of reductions we must reach an irreducible schedule. 

Define H(X) = (H^X), H 2 (X), . . . , H n (X)), where Hj(X) = Et&i.teX-^) 1 ' for each job j ' 
Given two different schedules X, y, we say that H(X) is lexicographically smaller than H(y), if 
Hi(X) < Hi(y) for the smallest i for which H^X) ^ H^y). 

If two jobs i < j are not in order, then the (i, j)-reduction decreases Hi(X), while Hj(X) 
increases. Therefore H(X) decreases lexicographically. Any value Hj(X) is integer and bounded 
by < Hj(X) < p(maxjCi), where maxj is preserved by the reductions. From this we can 
conclude that after a finite number of reductions we obtain an irreducible optimal schedule. □ 

We now give a characterization of irreducible schedules that will play a major role in the 
construction of our linear program. 

For a given job j and a time t we partition X (t) — {j} into jobs released before and after j. 
Formally, X < j(t) = {i € X(t) : i < j} and X > j(t) = {i E X(t) : i > j}. The lemma below provides 
a characterization of irreducible schedules. (See Figure 
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Figure 1: Structure of any irreducible schedule. 



Lemma 4 Let X be an irreducible schedule. Let u, t be two time points and k be a job such that 
fk < u < t. Then: 

(a) Ifke X(u) - X(t) then \X <k {t)\ < |A^ fc («)|. 

(b) Ifk 6 X(t) - X(u) then \X(u)\ = m, \X >k (t)\ > \X >k (u)\, and \X <k (t)\ < |Af <fc («)|. 

(c) Ifk € X(u)nX(t) then \X <k (t)\ < \X <k (u)\ and \X >k (t)\ > \X >k (u)\. 

Proof: Case (a) k S X(u) — X(t): We will show by contradiction that X <k (t) C X <k (u), so 
suppose that there is a job j G X <k (t) — X <k (u). Then j > mm(X <k (t) — X <k (u)) = min(Af(t) — 
X(u)). Also j < k, and k < m&x(X(u) — X(t)). This contradicts irreducibility by equation Q and 
thus (a) follows. 
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Case (b) k G X(t) — X(u): Since k g" X{u) and < u, the assumption that X is busy implies 
that |<-f = m. 

We must have X > k(u) C X > k(t), for otherwise, the existence of k G «^(*) — X(u) and an 
/ G Af>fc(it) — Af>fc(t) would contradict irreducibility. The inequality |^>fc(u)| < |^f>fc(i)| follows. 
This, the assumption of the case, and |A?(w)| = m imply |Af<fc(zi)| > lA^^t)]. 

Case (c) k G X(u) fl We only prove the first inequality, as the proof for the second one is 

very similar. Towards contradiction, suppose |A^ < fc(it)| < |Af<fc(i)|, and pick any i G X < f c (t) — X < i t (u). 
Then r% < < u and i G X(t) — X(u), and so the assumption that X is busy implies X(u) = m. 
This, in turn, implies that |Af>fc(?i)| > |AJ>fc(£)[, so we can choose j G X > ^(u) — X > k(t). But 
this means that j > k > i and j G X(u) — X(t), and the existence of such i and j contradicts 
irreducibility. □ 

3 A Linear Program for P\rf : pmtn; pj = p\Yl Cj 

Machine assignment. We now consider the actual job-machine assignment in an irreducible 
schedule X. As explained earlier, at every time t we assign the jobs in X(t) to machines in order, 
that is job j G X(t) is assigned to machine 1 + |^<j(t)|. Lemma implies that, for any fixed j, 
starting at t = rj the value of j^^t)) decreases monotonically with t. Therefore, with machine 
assignments taken into account, X will have the structure illustrated in Figure ^ 

Call a schedule X normal if for each job j and each machine q, job j is executed on q in a single 
(possibly empty) interval [Sj )g ,Cj iq ), and 

(1) Cj tq < Sj+iq for each machine q and job j < n, and 

(2) Cj >g < 5j,q-i for each machine q > 1 and job j. 

By the earlier discussion, every irreducible schedule is normal (although the reverse does not 
hold.) An example of a normal (and irreducible) schedule is shown in Figure [21 
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Figure 2: Example of a normal schedule. The processing time is p = 8. 
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Linear program. We are now ready to construct our linear program: 



minimize 



£"=i C jt i (2) 



subject to ~Sj,m < — Tj j = 1, . . . , n 



~ Sj,q) =P 3 = 1, 



~ Cj',? ^ j = l,...,n, q = l,...,m 

C j,q ~ S j,q-i ^ j = l,...,n, q = 2,...,m 

C j>q - Sj+i^g < j = 1, . . . , n - 1, q = 1, . . . , m 

The correspondence between normal schedules and feasible solutions to this linear program 
should be obvious. For any normal schedule, the start times Sj tq and completion times Cj q satisfy 
the constraints of (J2J). And vice versa, for any set of the numbers Sj >q , Cj tq that satisfy the 
constraints of (J2J, we get a normal schedule by scheduling any job j in interval [Sj_ q , Cj^ q ) on each 
machine q. Thus we can identify normal schedules X with feasible solutions of ((21) • Note, however, 
that in X a job j could complete earlier than Cj t \ (this can happen when Cji = <Sj,i-) Thus the 
only remaining issue is whether the optimal normal schedules correspond to optimal solutions of 



Theorem 5 The linear program above correctly computes an optimal schedule. More specifically, 
min^> Y2j Cj = min^^ Cj t i, where on the left-hand side the minimum is over normal schedules X 
with Cj representing the completion time of job j in X , and on the right-hand side we have the 
optimal solution of the linear program (j2J) . 

Proof: (<) By the correspondence between normal schedules and feasible solutions of ©, 
discussed before the theorem, we have Cj < Cj t \ for all j, and thus the < inequality is trivial. 

(>) To justify the other inequality, fix an optimal irreducible (and thus also normal) schedule 
X. We want to show a feasible solution to (j2J for which Cj = Cj t ± for all j. 

Fix a job j, and let [Sj g , Cj >g ) be the last (that is, the one with minimum g) non-empty execution 
interval of j. So Cj = Cj, g in X. Consider a block [s,t) where t = Cj jg . By Lemma all jobs 
executed on machines 1, 2, ... ,g — 1 in [s, t) are numbered lower than j. Further, by the ordering 
of completion times, they are not executed after t. Thus these jobs must be completed at t as well. 
Therefore we can set [Sj h,Cj t h) = [t,t), for all machines 1 < h < g. This gives a normal schedule 
in which Cj = Cj\. 

Having done this for all jobs, we will get numbers Sj ;9 and Cj iq that satisfy all constraints of 
the linear program, and such that Cj = Cj t \ for all j. □ 



4 Unary NP-Hardness of P\rj, pmtn| ^ Cj 

In this section we prove that without the assumption on equal processing times the problem is 
strongly (unary) NP-hard. 

Theorem 6 The problem P\rj, pmtn| Cj is strongly NP-hard, that is, it is NP-hard even if the 
numbers on input are represented in the unary encoding. 
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Proof: The proof is by reduction from 3-Partition. In an instance I of 3-Partition we 
have 3n + 1 numbers xi, X2, • • • , x$ n , V such that Yli=i x i = n V an d \v < x % < \\) f° r each i. We 
want to determine whether there is a partition of {1, 2, . . . , 3n} into n sets S\, . . . ,S n such that 
X^ieS fe x i = V f° r an (By the assumption about the numbers Xi, in any such partition all sets Sk 
have exactly three elements.) 

Given an instance of 3-Partition above, we construct an instance J of P|rj,pmtn| Yl^j as 
follows. Define A = 6ny and B = 18n 2 y 2 . We let m = n, and N = An + An. We create three types 
of jobs: 

x-jobs: For each j = 1, . . . , 3n, we create job j with r,- = and pj = Axj. 
B-jobs: For each j = 3n + 1, . . . , An, we create job j with rj = Ay and pj = B. 
1-jobs: For each j = An + 1, . . . , N, we create job j with r,- = Ay + i? and pj = 1. 

If X is represented in unary, its size is ®(ny). Then the size of J (in unary encoding) is 
polynomial and the above transformation works in polynomial time. 

Thus now it is sufficient to prove the following claim: X has a 3-partition if and only if J has 
a schedule with YljLi Q < D, where D = 3nAy + n(Ay + B) + n J2f = i(Ay + B + i). 

(=>) Let Si, . . . , S n be a 3-partition of I. For each fc we have ^jG5 fc % = ^° on mac hi ne ^ 
we schedule the following jobs: first the three x-jobs j £ S^, completing the last one at Ay, then 
one B-job, followed by A 1-jobs. The objective value of this schedule is 

N A 

^ 3nAy + n(Ay + B) + n^2(Ay + B + i) = D. 

3=1 i=l 

(<=) Suppose now that I does not have a 3-partition. Consider any schedule X of J on n 
machines. We want to prove that the value of the objective function for X exceeds D. 
We consider easy cases first. If some x-job is completed after time Ay + B then 

N A 

> Ay + B + n(Ay + B) + nJ2( A y + B + i ) > D - 

j=l i=l 

If some B-job is completed after time Ay + 2B then 

N A 

Y,Cj > (n - l)(Ay + B) + Ay + 2B + n^{Ay + B + i) > D. 

j=l i=l 

Suppose now that each x-job is completed no later than at time Ay + B and each B-job is completed 
no later than at time Ay + IB. Since X does not have a 3-partition, some machine is idle for A 
time units in the interval [0, .Ay]. Therefore some B-job will complete between Ay + B + A and 
Ay + 2B, keeping one machine busy in the interval [Ay + B, Ay + B + A]. This implies that there 
are at least A 1-jobs that will be scheduled at time Ay + A + B or later. Thus 

N A 

> (n-l){Ay + B) + Ay + A + B + (n-l)^2(Ay + B + i)+A(Ay + A + B) > D. 

3=1 i=l 

Summarizing, in all cases the objective value exceeds D, completing the proof of the claim. □ 



S 



5 Final Remarks 



We proved that the scheduling problem P\rj, pmtn, pj = p\Yl Cj can be reduced to solving a linear 
program with 0(mn) variables and constraints. This leads to a simple polynomial time algorithm. 
Since we can assume that m < n (otherwise the problem is trivial) the running time can be also 
expressed as a polynomial of n only. 

We showed that there is an optimal schedule with 0{mn) preemptions. We do not know whether 
this bound is asymptotically tight. It is quite possible that there exist optimal schedules in which 
the number of preemptions is 0(n), independent of m. If this is true, this could lead to even 
more efficient, combinatorial (not dependent on linear programming) algorithms for this problem. 
Such improvement, however, would require a deeper study of the structural properties of optimal 
schedules. Since we use only the existence of normal optimal schedules, rather than irreducible 
schedules, we feel that the problem has more structure to be exploited. 

An interesting related open question is P\rj,pj = p\ Uj, where the objective is to find a maxi- 
mal subset of jobs which can be scheduled on time. It has been shown in [H] that the corresponding 
preemptive version, P\rj,pj = p, pmtn| Uj, is unary NP-hard. 

We implemented the complete algorithm (converting the instance to a linear program and 
solving this linear program). It is accessible at Christoph Diirr's webpage. 
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A Proof of Theorem [3] for Arbitrary Real Numbers 



In Section |21 we proved that there is always an optimal irreducible schedule, under the assumption 
that the processing time p and the release times ri,...,r n are integral. We now show that this is 
true in the more general scenario when all these numbers are arbitrary reals. 

We first extend the definition of the potential function. For any job j, let Hj(X) = ~ f x -i(j) *dt, 
where the integral is taken over the support of j. (We remark that this is a standard value 
in scheduling, even though the factor | is irrelevant for this paper.) The generalized potential 
function is H{X) = {B\(X), ■ ■ .,H n (X)). 

The following properties remain true: (i) a reduction does not increase the objective function 
and preserves the property of a schedule being busy, (ii) H(X) strictly decreases (lexicographically) 
after each reduction. 

The major difficulty that we need to overcome is that the set of schedules is not closed as a 
topological space, so there could be a sequence of schedules with decreasing values of H(X) whose 
limit is not a legal schedule. The idea of the proof is to reduce the problem to minimizing H(X) 
over a compact subset of schedules. 

Lemma 7 Even ifp,r±, ... ,r n are arbitrary real numbers, there is an irreducible optimal schedule. 

Proof: Define a block of a schedule X to be a maximal time interval [u, t) such that (u, t) does 
not contain any release times and X(s) is constant for s £ [it, t). 

For convenience, let r n+ \ be any upper bound on the last completion time of any optimal 
schedule, say r n+ \ = r n + rip. Thus all jobs are executed between r\ and r n+ \. Each interval 
[n, rj-j-i), for i = 1, . . . , n is called a segment. By condition (s3), each segment is a disjoint union of 
a finite number of blocks of X . Also, for each job j, we have Cj = t for the last non-empty block 
[s,t) whose profile contains j. 

A schedule X is called tidy if all jobs are completed no later than at r n+ \ and, for any segment 
[rj,rj + i), the profiles X(t), for t G [r^, rj+i), are lexicographically ordered from left to right. More 
precisely, this means that, for any n < s < t < r^x, we have 

mm(X(s) - X(t)) < mm(X(t) - X(s)). 

One useful property of tidy schedules is that its total number of blocks (including the empty ones) 
is N = nM, where M = Y^b=o (?)> because n is the number of intervals [rf, rj+i) and M is the 
number of lexicographically ordered blocks in each interval. From now on we identify any tidy 
schedule X with the vector X £ M. N whose 6-th coordinate Xb represents the length of the 6-th 
block in X. 

In fact, the set T of tidy schedules is a (compact) convex polyhedron in M. N , for we can describe 
T with a set of linear inequalities that express the following constraints: 

• Each job j is not executed before rj, 

• Each job j is executed for time p. 

For example, the second constraint can be written as Xb = p, where the sum is over all blocks 
6 whose profile contains j. 

Claim 8 Any schedule X can be transformed into a schedule with completion times ordered as 
C\ < . . . < C n , without increasing the objective function value. 
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Proof: Note that after an (i, j')-reduction we have Cj < Cj, and no other completion time is 
changed. Therefore after reducing job 1 successively with the jobs 2, . . . , n, C\ is the smallest com- 
pletion time. Then after reducing job 2 with the jobs 3, . . . , n we have C\ < C2 < min{C3, . . . , C n }. 
Continuing this process will eventually end with ordered completion times. □ 

Claim 9 Let X be a schedule in which completion times are ordered and upper bounded by r n+ \. 
Then X can be converted into a tidy schedule X' such that 

(a) C'j < Cj for all j (where Cj and Cj are the completion times of j in X and X' , respectively.) 

(b) H(X') is equal to or lexicographically smaller than H(X). 

Proof: Indeed, suppose that X has two consecutive blocks A = [u, s), B = [s,t) where rj < 
u < s < t < rj + i, and the profile X(u) of A is larger (lexicographically) than the profile X(s) of 
B. Exchange A and B, and denote by X' the resulting schedule. Let j = mm(X(s) — X{u)) < 
mm(X(u) — X(s)). Since Cj > t, all jobs in X(u) — X(s) are also completed not earlier than 
at t. So this exchange does not increase any completion times. We have Hj(X') < Hj(X) and 
Hi(X') = Hi(X) for i < j. Thus H(X') is lexicographically smaller than H(X). By repeating this 
process, we eventually convert X into a tidy schedule that satisfies the claim. □ 

We now continue the proof of the lemma. Fix some optimal schedule X*. Let denote the 
completion time of a job j in X*. From Claims |H1 and we can assume that X* is tidy and 
C* < C| < . . . < C*. (For the peace of mind, it is worth noting that Claim |H1 implies that X* is 
well defined, for it reduces the problem to minimizing ^ . Cj over a compact subset T of M. N .) 

Consider a class To C T of tidy schedules X such that each job j in X is completed not later 
than at time C*j . Since X* € To, the set To is not empty. Similarly as T, To is a (compact) 
convex polyhedron. Indeed, we obtain To by using the same constraints as for T and adding the 
constraints that each job j is completed not later than at CJ. To express this constraint, if in X* 
the completion time Cj of j is at the end of the a-th block in the segment [n,ri+i), then for each 
b > (i — 1)M + a such that j is in the profile of the 6-th block, we would have a constraint = 0. 
Note that these constraints do not explicitly force j to end exactly at C*, but the optimality of X* 
guarantees that it will have to. 

Now we show that there exists a schedule y* € To for which H{y*) is lexicographically mini- 
mum. First, as we explained earlier, To is a compact convex polyhedron. Let Ti C To be the set 
of X for which H\(X) is minimized. H\ is a continuous quadratic function over To, and thus Ti 
is also a non-empty compact set. Continuing this process, we construct sets T2, . . . , T n , and we 
choose y* arbitrarily from T n . □ 
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